<!DOCTYPE HTML>
<title>auxclick is a PointerEvent</title>
<meta name="variant" content="?mouse">
<meta name="variant" content="?pen">
<link rel="help" href="https://github.com/w3c/pointerevents/pull/317">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-actions.js"></script>
<script src="/resources/testdriver-vendor.js"></script>

<input id="target" style="margin: 20px">

<script>
'use strict';
let target = document.getElementById("target");
let pointerId = 0;
let pointerType = "";
let inputSource = location.search.substring(1);

target.addEventListener("pointerdown", (e)=>{
  pointerId = e.pointerId;
  pointerType = e.pointerType;
});

function testFunction(test){
  return test.step_func(e=>{
    assert_equals(e.constructor, window.PointerEvent, "auxclick should use a PointerEvent constructor");
    assert_true(e instanceof PointerEvent, "auxclick should be a PointerEvent");
    assert_equals(e.pointerId, pointerId, "auxclick's pointerId should match the pointerId of the pointer event that triggers it");
    assert_equals(e.pointerType, pointerType, "axclick's pointerType should match the pointerType of the pointer event that triggers it");
  });
}

function run_test(pointerType){
  promise_test((test) => new Promise((resolve, reject) => {
    const testPointer = pointerType + "TestPointer";
    let auxclickFunc = testFunction(test);
    test.add_cleanup(() => {
      target.removeEventListener("auxclick", auxclickFunc);
      pointerId = 0;
      pointerType = "";
    });
    target.addEventListener("auxclick", auxclickFunc);
    let eventWatcher = new EventWatcher(test, target, ["auxclick"]);
    let actions = new test_driver.Actions();
    actions = actions
      .addPointer(testPointer, pointerType)
      .pointerMove(0,0, {origin:target, sourceName:testPointer})
      .pointerDown({button:actions.ButtonType.MIDDLE, sourceName:testPointer})
      .pointerUp({button:actions.ButtonType.MIDDLE, sourceName:testPointer});
    Promise.all([eventWatcher.wait_for("auxclick"), actions.send()]).then(()=>resolve());
  }), "auxclick using " + pointerType + " is a PointerEvent");
}

run_test(inputSource);
// TODO(crbug.com/1150441): Add test for auxclick from touch.Note: Calling run_test("touch") here times out.
</script>
